home *** CD-ROM | disk | FTP | other *** search
/ Cream of the Crop 1 / Cream of the Crop 1.iso / PROGRAM / DJLSR106.ARJ / MEMCMP.C < prev    next >
C/C++ Source or Header  |  1992-03-02  |  2KB  |  54 lines

  1. /* This is file MEMCMP.C */
  2. /* This file may have been modified by DJ Delorie (Jan 1991).  If so,
  3. ** these modifications are Coyright (C) 1991 DJ Delorie, 24 Kirsten Ave,
  4. ** Rochester NH, 03867-2954, USA.
  5. */
  6.  
  7. /*-
  8.  * Copyright (c) 1990 The Regents of the University of California.
  9.  * All rights reserved.
  10.  *
  11.  * This code is derived from software contributed to Berkeley by
  12.  * Chris Torek.
  13.  *
  14.  * Redistribution and use in source and binary forms are permitted
  15.  * provided that: (1) source distributions retain this entire copyright
  16.  * notice and comment, and (2) distributions including binaries display
  17.  * the following acknowledgement:  ``This product includes software
  18.  * developed by the University of California, Berkeley and its contributors''
  19.  * in the documentation or other materials provided with the distribution
  20.  * and in all advertising materials mentioning features or use of this
  21.  * software. Neither the name of the University nor the names of its
  22.  * contributors may be used to endorse or promote products derived
  23.  * from this software without specific prior written permission.
  24.  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
  25.  * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
  26.  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
  27.  */
  28.  
  29. #if defined(LIBC_SCCS) && !defined(lint)
  30. static char sccsid[] = "@(#)memcmp.c    5.5 (Berkeley) 5/15/90";
  31. #endif /* LIBC_SCCS and not lint */
  32.  
  33. #include <string.h>
  34. #include <sys/stdc.h>
  35.  
  36. /*
  37.  * Compare memory regions.
  38.  */
  39. int
  40. memcmp(s1, s2, n)
  41.     const void *s1, *s2;
  42.     int n;
  43. {
  44.     if (n != 0) {
  45.         register const unsigned char *p1 = s1, *p2 = s2;
  46.  
  47.         do {
  48.             if (*p1++ != *p2++)
  49.                 return (*--p1 - *--p2);
  50.         } while (--n != 0);
  51.     }
  52.     return (0);
  53. }
  54.